package workexp.alg.question;

/*给定一个字符串，验证它是否是回文串，只考虑字母和数字字符，可以忽略字母的大小写。

        说明：本题中，我们将空字符串定义为有效的回文串。

         

        示例 1:

        输入: "A man, a plan, a canal: Panama"
        输出: true
        解释："amanaplanacanalpanama" 是回文串
        示例 2:

        输入: "race a car"
        输出: false
        解释："raceacar" 不是回文串

        作者：力扣 (LeetCode)
        链接：https://leetcode-cn.com/leetbook/read/top-interview-questions-easy/xne8id/
        来源：力扣（LeetCode）
        著作权归作者所有。商业转载请联系作者获得授权，非商业转载请注明出处。*/

import org.junit.Test;

import javax.xml.stream.events.Characters;

public class IsPalindrome {

    public boolean isPalindrome(String s) {
        int left=0;
        int right=s.length()-1;
        s =s.toLowerCase();
        while(left<right){
            while(left<right&&!Character.isLetterOrDigit(s.charAt(left))){
                left++;
            }
            while(left<right&&!Character.isLetterOrDigit(s.charAt(right))){
                right--;
            }
            if(Character.toLowerCase(s.charAt(left))==Character.toLowerCase(s.charAt(right))){
                left++;
                right--;
                continue;
            }else{
                return false;
            }
        }
            return true;
    }


    @Test
    public void test(){
        String s = "woccow";
        boolean flag =  isPalindrome(s);
        System.out.println(flag);
    }
}
